body {
    font-family: 'Roboto', sans-serif;
    background-color: #065818;
}

/* Contenedor general del dashboard */
.dashboard-container {
    display: flex;
    height: 100vh;
    background-color: #F0F7FF;
    overflow: hidden; /* Evita scroll si es posible */
}

/* Sidebar y logo */
.sidebar {
    background-color: #040708; /* Azul oscuro del logo */
    width: 250px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.logo img {
    width: 120px;
    margin-bottom: 30px;
}

/* Menú de navegación */
.menu {
    list-style: none;
    padding: 0;
    width: 100%;
}

.menu li {
    margin: 15px 0;
}

.menu li a {
    color: #fff;
    text-decoration: none;
    font-size: 18px;
    display: flex;
    align-items: center;
    padding: 15px;
    border-radius: 8px;
    transition: background-color 0.3s, transform 0.2s ease-in-out;
}

.menu li a i {
    margin-right: 10px;
}

.menu li a:hover,
.menu li a.active {
    background-color: #00C2FF; /* Azul claro del logo */
    transform: translateY(-3px); /* Efecto de hover dinámico */
}

/* Área de contenido */
.content-area {
    flex-grow: 1;
    padding: 40px;
    background-color: #178551;
    transition: opacity 0.4s ease-in-out; /* Transición al cambiar de pestaña */
    margin-left: 250px; /* Deja espacio para la barra lateral */
      height: calc(100vh - 40px); /* Ajusta altura según el padding */
    overflow-y: auto; /* Permite scroll dentro del área de contenido */
}

.content-area section {
    display: none; /* Oculto por defecto */
}

.content-area section.active {
    display: block; /* Muestra solo cuando esté activo */
    max-width: 900px; /* Ancho máximo para que no se extienda demasiado */
    margin: 0 auto; /* Centrado */
    background-color: #ffffff; /* Fondo blanco para las secciones */
    padding: 25px; /* Padding interno para separación del borde */
    border-radius: 8px; /* Bordes redondeados */
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); /* Sombra ligera */
}


/* Barra de progreso */
.progress-bar-container {
    margin: 20px 0;
    text-align: center;
}

.progress-bar {
    background-color: #e0e0e0;
    border-radius: 8px;
    overflow: hidden;
    height: 20px;
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
}

.progress-bar-fill {
    height: 100%;
    background-color: #178551;
    transition: width 0.5s ease-in-out;
}

/* Modo oscuro */
body.dark-mode {
    background-color: #2b2b2b;
    color: #e0e0e0;
}

body.dark-mode .sidebar {
    background-color: #1f1f1f;
}

body.dark-mode .menu li a {
    color: #e0e0e0;
}

body.dark-mode .content-area {
    background-color: #3a3a3a;
}
/* Ajustes del sidebar */
.sidebar {
    background-color: #178551; /* Azul oscuro */
    height: 100vh;
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: 250px; /* Asegura que tenga un ancho constante */
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 20px;
    z-index: 10; /* Para asegurarse que esté encima del contenido */
}

.menu li a {
    font-size: 16px; /* Ajustando el tamaño de fuente */
    padding: 12px; /* Más espaciado */
    transition: background-color 0.3s, padding 0.3s;
}

.menu li a:hover {
    background-color: #00C2FF;
    padding-left: 20px; /* Animación al hover */
}

/* Estilos para el área de contenido */
.content-area {
    padding: 50px;
    background-color: #F8F9FA;
}

h1 {
    color: #178551;
    font-size: 28px;
    font-weight: bold;
}



.logout-btn {
    color: #ff4d4d; /* Rojo claro para resaltar */
    font-weight: bold;
    transition: background-color 0.3s, padding 0.3s;
}

.logout-btn:hover {
    background-color: #ff9999;
    padding-left: 20px; /* Animación de hover */
}
.welcome-message {
    text-align: center;
    margin-bottom: 30px;
}

.welcome-message h2 {
    color: #178551; /* Color del logo */
    font-size: 24px;
    font-weight: bold;
}
.welcome-message {
    text-align: center;
    margin-bottom: 30px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: calc(100vh - 150px); /* Ajustamos para centrarlo mejor */
}
#poweredby {
    text-align: center;
    margin-top: 20px;
    color: #178551; /* Ajuste de color del logo */
    font-size: 16px;
    font-weight: bold;
}
.logout-btn {
    position: absolute;
    top: 20px;
    right: 20px;
    background-color: #178551; /* Azul del logo */
    color: white;
    padding: 10px;
    border-radius: 8px;
    font-weight: bold;
    transition: background-color 0.3s;
}

.logout-btn:hover {
    background-color: #8c0b0b; /* Azul claro */
}
.footer {
    background-color: #178551;
    color: white;
    text-align: right;
    padding: 10px 20px;
    font-size: 10px;
    position: fixed;
    bottom: 0;
    left: 250px; /* Ajuste para que empiece desde el borde derecho de la sidebar */
    width: calc(100% - 250px); /* Ancho para evitar que sobresalga de la barra lateral */
    box-sizing: border-box;
}
.fade-in-image {
    position: fixed;
    width: 100%;
    height: 100%;
    background-color: white; /* Fondo opcional */
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1000; /* Aparece por encima de todo */
}

.fade-in-image img {
    animation: fadeOut 3s forwards; /* Duración y acción de desvanecerse */
}

@keyframes fadeOut {
    0% {
        opacity: 1;
    }
    100% {
        opacity: 0;
        display: none;
    }
}
/* Centrando la sección de perfil */
#profile {
    display: none; /* Oculto por defecto */
    text-align:center;
    margin: 0 auto;
    position:fixed;
    z-index: 10;
    margin-top: 70px;
    margin-left: 250;
    align-items: center;
    display: flex;
    justify-content: center;
}
#profile {
    display: block;
}

.profile-actions {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 20px;
}

.profile-actions .btn {
    background-color: #178551;
    color: white;
    border: aqua;
    padding: 10px 20px;
    border-radius: 5px;
    cursor: pointer;
}

.profile-actions .btn:hover {
    background-color: #005bb5;
    margin-bottom: 40px;
}

.profile-section, .plan-info-section {
    background-color: #fff; /* Puedes ajustar colores aquí */
    padding: 20px;
    border-radius: 5px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); /* Sombra ligera para darle estilo */
    
}


.profile-section h2, .plan-info-section h2 {
    font-weight: bold; /* Resaltar el título */
    font-size: 1.8rem; /* Tamaño de fuente grande para el título */
    margin-bottom: 15px; /* Espacio debajo del título */
}

/* Estilos para los párrafos dentro de las secciones */
.profile-section p, .plan-info-section p {
    line-height: 1.6; /* Mejorar la legibilidad aumentando la altura de línea */
    margin-bottom: 10px; /* Espacio entre los párrafos */
}

/* Estilos para los botones de la sección de perfil */
.profile-section button {
    margin-right: 10px; /* Espacio entre los botones */
    padding: 10px 15px; /* Tamaño del botón */
    background-color: #178551; /* Color azul para los botones */
    color: white; /* Texto blanco */
    border: none; /* Sin borde */
    border-radius: 5px; /* Botones redondeados */
    cursor: pointer; /* Cambiar el cursor al pasar sobre el botón */
}

.profile-section button:hover {
    background-color: #0056b3; /* Color más oscuro al pasar el ratón */
}

/* Ajustes de diseño para pantallas más pequeñas */
@media (max-width: 768px) {
    .user-info {
        flex-direction: column; /* Colocar las secciones una debajo de la otra */
    }

    .plan-info-section {
        margin-left: 0; /* Alinear la sección del plan al centro en pantallas pequeñas */
        max-width: 100%; /* Que la sección del plan ocupe todo el ancho disponible */
        margin-top: 40px;
    }
}
.profile-container {
    display: flex;
    justify-content: space-between; /* Espacio entre columnas */
    gap: 40px; /* Espacio entre la columna izquierda y derecha */
    margin-top: 20px;
    align-items: stretch;
}

/* Columna izquierda: Información del Usuario */
.user-info, .plan-info-section {
    flex: 1;
    padding: 20px;
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
    justify-content: space-between; /* Asegura que el contenido interno esté bien distribuido */
}


/* Botones dentro de la columna de usuario */
.profile-actions {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 20px;
}

/* Botones individuales */
.profile-actions .btn {
    background-color: #178551;
    color: white;
    border: none;
    padding: 10px 20px;
    border-radius: 5px;
    cursor: pointer;
}

.profile-actions .btn:hover {
    background-color: #005bb5;
}

/* Responsivo: en pantallas más pequeñas las columnas se apilan verticalmente */
@media (max-width: 768px) {
    .profile-container {
        flex-direction: column; /* Las columnas se apilan verticalmente */
    }

    .user-info, .plan-info-section {
        width: 100%; /* Asegura que ocupen todo el ancho disponible */
    }
}
.form-style {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-top: 20px;
}

.form-control {
    padding: 10px;
    border-radius: 8px;
    border: 1px solid #ddd;
    font-size: 16px;
    width: 100%;
}

.btn {
    background-color: #178551;
    color: white;
    padding: 10px 20px;
    border-radius: 8px;
    cursor: pointer;
    border: none;
    font-size: 16px;
}

.btn:hover {
    background-color: #005bb5;
}
section {
    display: none;
}

section.active {
    display: block;
}
/* Contenedor de chat centrado y más pequeño */
#chat-container {
    max-width: 600px; /* Contenedor más pequeño */
    height: 500px; /* Altura más compacta */
    margin: 40px auto; /* Centrado automático */
    background-color: #5c77bd; /* Fondo con mayor contraste para el logo blanco */
    padding: 20px;
    border-radius: 15px;
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.15); /* Sombra para mayor profundidad */
    background-image: url('/img/AVOGALUSOLOLETRABLANCA500X500Logo.png');
    background-size: 200px; /* Tamaño del logo ajustado */
    background-position: center center;
    background-repeat: no-repeat;
    opacity: 1; /* Aumenta la visibilidad del logo */
    transition: transform 0.3s ease-in-out;
}

/* Hover en el contenedor para añadir interacción */
#chat-container:hover {
    transform: scale(1.02); /* Efecto de zoom sutil */
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15); /* Efecto de sombra mejorado */
}

/* Área donde se mostrarán los mensajes */
.chat-messages {
    flex-grow: 1;
    overflow-y: auto;
    overflow-y: scroll !important;
    margin-bottom: 10px;
    padding-right: 10px;
    max-height: 100% !important;
}

/* Mensajes del usuario y bot con diseño unificado */
.message {
    padding: 12px 20px;
    margin: 10px 0;
    border-radius: 20px;
    max-width: 75%;
    word-wrap: break-word;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
    transition: background-color 0.3s ease;
}

/* Mensajes del usuario */
.user-message {
    background-color: #178551;
    color: white;
    align-self: flex-end;
    border-top-right-radius: 0;
}

/* Hover en los mensajes del usuario */
.user-message:hover {
    background-color: #005bb5;
}

/* Mensajes del bot */
.bot-message {
    background-color: #f1f1f1;
    color: #333;
    align-self: flex-start;
    border-top-left-radius: 0;
}

/* Hover en los mensajes del bot */
.bot-message:hover {
    background-color: #e2e2e2;
}

/* Efecto fade-in al aparecer los mensajes */
@keyframes fadeIn {
    from { opacity: 0.7; transform: translateY(20px); }
    to { opacity: 0.9; transform: translateY(0); }
}

.message {
    animation: fadeIn 0.4s ease-in-out;
}

/* Contenedor del input de chat */
.chat-input-container {
    display: flex;
    border-top: 2px solid #ccc;
    padding-top: 15px;
    background-color: #5c77bd; /* Coincide con el color del contenedor principal */
    border-radius: 0 0 15px 15px;
    box-shadow: 0 -4px 10px rgba(0, 0, 0, 0.05);
}

/* Campo de entrada de texto */
.chat-input {
    flex-grow: 1;
    padding: 12px;
    border-radius: 8px;
    border: 2px solid #ccc; /* Borde definido para mayor visibilidad */
    font-size: 16px;
    outline: none;
    transition: border-color 0.3s ease;
}

/* Efecto en foco del input */
.chat-input:focus {
    border-color: #178551;
}

/* Botón de enviar mensaje */
.chat-send-btn {
    background-color: #178551;
    color: white;
    padding: 12px 20px;
    border-radius: 8px;
    border: none;
    margin-left: 10px;
    cursor: pointer;
    font-size: 16px;
    transition: background-color 0.3s ease;
}

/* Hover en el botón de enviar */
.chat-send-btn:hover {
    background-color: #005bb5;
}

/* Efecto activo en el botón de enviar */
.chat-send-btn:active {
    transform: scale(0.95);
}
.form-control:hover {
    border-color: #178551; /* Darker blue for hover */
}

.form-control:focus {
    border-color: #005bb5;
    outline: none;
    box-shadow: 0 0 5px rgba(0, 119, 225, 0.5);
}
/* Contenedor principal del formulario */
.form-container {
    display: flex;
    gap: 20px;
    margin-top: 20px;
}

/* Columnas del formulario */
.form-column {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

/* Estilo de los labels */
label {
    font-weight: bold;
    color: #333;
    margin-bottom: 5px;
    font-size: 14px;
}

/* Estilo de los inputs */
.form-control {
    padding: 10px;
    border-radius: 6px;
    border: 1px solid #ccc;
    font-size: 14px;
    transition: border-color 0.3s;
}

/* Efecto hover y focus en los inputs */
.form-control:hover, .form-control:focus {
    border-color: #178551;
    outline: none;
    box-shadow: 0 0 5px rgba(0, 119, 225, 0.2);
}

/* Ajustes responsive para pantallas pequeñas */
@media (max-width: 768px) {
    .form-container {
        flex-direction: column;
    }
}
/* Contenedor principal del formulario de notificaciones */
#notificaciones {
    max-width: 900px; /* Ancho máximo del formulario */
    padding: 25px; /* Espacio interno para mantener separación en los bordes */
    background-color: #ffffff; /* Fondo blanco para contraste */
    border-radius: 10px; /* Bordes redondeados */
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); /* Sombra ligera para realzar el contenedor */
    margin: 20px auto; /* Centra el contenedor en la página */
}

/* Contenedor de las columnas del formulario */
.form-container {
    display: flex;
    gap: 20px; /* Espacio entre columnas */
    flex-wrap: wrap; /* Permite que las columnas se ajusten en pantallas pequeñas */
}

/* Columnas del formulario */
.form-column {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px; /* Espacio entre los campos dentro de cada columna */
}

/* Campos de entrada */
.form-control {
    max-width: 280px; /* Ancho máximo de cada campo para evitar estiramiento excesivo */
    width: 100%; /* Ocupa el 100% del espacio permitido por el contenedor */
    padding: 8px 12px; /* Espaciado interno para una mejor usabilidad */
    margin: 0 auto; /* Centrado dentro de la columna */
    border: 1px solid #ccc; /* Borde claro para diferenciar los campos */
    border-radius: 5px; /* Bordes redondeados para un diseño moderno */
    font-size: 14px; /* Tamaño de fuente estándar */
    transition: border-color 0.3s ease; /* Suaviza el cambio de color de borde */
}

/* Efecto hover y focus en los campos */
.form-control:hover, 
.form-control:focus {
    border-color: #178551; /* Color de borde azul al hacer hover/focus */
    box-shadow: 0 0 5px rgba(0, 119, 225, 0.2); /* Sombra ligera en focus */
    outline: none;
}

/* Título de la sección de notificaciones */
#notificaciones h1 {
    font-size: 24px;
    color: #178551; /* Azul para destacar el título */
    text-align: center;
    margin-bottom: 20px;
    font-weight: bold;
}

/* Ajustes para el botón de envío */
#generar-notificacion {
    width: 100%; /* Botón de ancho completo */
    padding: 10px;
    background-color: #178551;
    color: white;
    font-size: 16px;
    font-weight: bold;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

#generar-notificacion:hover {
    background-color: #005bb5; /* Color más oscuro al hacer hover */
}

/* Ajuste de separación vertical entre campos */
.form-control {
    margin-bottom: 12px; /* Espacio entre campos para mejorar la legibilidad */
}

/* Estilos de textarea */
textarea.form-control {
    resize: vertical; /* Permite ajustar el tamaño vertical */
}

/* Responsivo: en pantallas pequeñas, las columnas se apilan */
@media (max-width: 768px) {
    .form-container {
        flex-direction: column; /* Apila las columnas en dispositivos móviles */
    }

    #notificaciones {
        max-width: 90%; /* En pantallas pequeñas, ocupa el 90% del ancho */
    }
}
